package com.eltsistemas.dao;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;

import com.eltsistemas.modelo.Categoria;

public class CategoriaDao {
	
	private Session session;
	
	public CategoriaDao(Session session)
	{
		this.session=session;
	}
	
	public void adiciona(Categoria categoria)
	{
		session.save(categoria);
		session.getTransaction().commit();
	}
	
	public List<Categoria> lista()
	{
		return session.createCriteria(Categoria.class).list();
	}
	
	public Categoria exibe(Categoria categoria)
	{
		Categoria encontradoCategoria = (Categoria) session.load(Categoria.class, categoria.getId());
		return encontradoCategoria;
	}
	
	public void altera(Categoria categoria)
	{
		session.update(categoria);
		session.getTransaction().commit();
	}
	
	public void remover(Categoria categoria)
	{
		session.delete(categoria);
		session.getTransaction().commit();
	}

	public Categoria buscaCodigo(String nome)
	{
		// TODO Auto-generated method stub
		
		Query query = this.session.createQuery("from Categoria " +
				"where nome = :nome");
				query.setString("nome", nome);
				
		Categoria encontradoCategoria = (Categoria) query.uniqueResult();
		return encontradoCategoria;
		
	}
	
}
